/* 封装axios用于发送请求 */
import axios from 'axios'
import { Toast } from 'vant'
import store from "@/store/index";
// 创建一个新的axios实例
const instance = axios.create({
  baseURL: 'http://cba.itlike.com/public/index.php?s=/api/',
  timeout: 5000
})

// 添加请求拦截器
instance.interceptors.request.use(function (config) {
  // 在发送请求之前做些什么
  Toast.loading({
    message: '请求中...',
    forbidClick: true,      // 禁止点击
    loadingType: 'spinner',   // loading图标
    duration: 0     // 不会自动消失
  })

  // 只要有token， 就在请求时携带，便于请求需要授权的接口
  const token = store.getters.token
  if (token) {
    config.headers['Access-Token'] = token
    config.headers.platform = 'H5'
  }

  return config
}, function (error) {
  // 对请求错误做些什么
  return Promise.reject(error)
})

// 添加响应拦截器
instance.interceptors.response.use(function (response) {
  // 对响应数据做点什么
  const res = response.data
  if (res.status !== 200) {
    // 给错误提示， Toast默认是单例模式，后面的 Toast调用了，会将前一个Toast效果覆盖
    // 同时只能存在一个 Toast
    Toast(res.message)
    // 抛出错误promise
    return Promise.reject(res.message)
  } else {
    // 正确情况  直接走业务逻辑， 清除loading效果
    Toast.clear()
  }
  return res
}, function (error) {
  // 对响应错误做点什么
  return Promise.reject(error)
})

export default instance